std::atomic_store, std::atomic_store_explicit
From Cppreference
| Defined in header <atomic>
| ||
| template< class T >
void atomic_store( std::atomic<T>* obj, T desr ); | (1) | (since C++11) |
| template< class T >
void atomic_store( volatile std::atomic<T>* obj, T desr ); | (2) | (since C++11) |
| template< class T >
void atomic_store_explicit( std::atomic<T>* obj, T desr, | (3) | (since C++11) |
| template< class T >
void atomic_store_explicit( volatile std::atomic<T>* obj, T desr, | (4) | (since C++11) |
1-2) Atomically replaces the value pointed to by obj with the value of desr as if by obj->store(desr)
3-4) Atomically replaces the value pointed to by obj with the value of desr as if by obj->store(desr, order)
Contents |
[edit] Parameters
| obj | - | pointer to the atomic object to modify |
| desr | - | the value to store in the atomic object |
| order | - | the memory sycnhronization ordering for this operation: only std::memory_order_relaxed, std::memory_order_release and std::memory_order_seq_cst are permitted. |
[edit] Return value
none.
[edit] Exceptions
[edit] See also
| (C++11) | atomically replaces the value of the atomic object with a non-atomic argument (public member function of std::atomic) |
| (C++11) (C++11) | atomically obtains the value stored in an atomic object (function template) |
| (C++11) | defines memory ordering constraints for the given atomic operation (typedef) |
| specializes atomic operations for std::shared_ptr (function template) | |